package co.inventario.modelo.fachada;

import java.sql.SQLException;
import java.util.ArrayList;

import co.inventario.entidad.CajaDTO;
import co.inventario.modelo.negocio.CajaNegocio;
import co.inventario.transversal.DAOFactorySQLServer;

public class CajaFachada {

	public void crear(CajaDTO cajaDTO) throws Exception {
		DAOFactorySQLServer daoFactorySQLServer = new DAOFactorySQLServer();
		CajaNegocio cajaNegocio = new CajaNegocio();
		try {
			cajaNegocio.crear(cajaDTO, daoFactorySQLServer.obtenerConexion());
			daoFactorySQLServer.confirmarTransaccion();
		} catch (SQLException exception) {
			daoFactorySQLServer.cancelarTransaccion();
			throw new Exception("Se ha presentado un problema intentando crear un dato en la caja.");
		} catch (Exception exception) {
			daoFactorySQLServer.cancelarTransaccion();
			throw exception;
		} finally {
			daoFactorySQLServer.cerrarConexion();
		}
	}

	public void actualizar(CajaDTO cajaDTO) throws Exception {
		DAOFactorySQLServer daoFactorySQLServer = new DAOFactorySQLServer();
		CajaNegocio cajaNegocio = new CajaNegocio();
		try {
			cajaNegocio.actualizar(cajaDTO, daoFactorySQLServer.obtenerConexion());
			daoFactorySQLServer.confirmarTransaccion();
		} catch (SQLException sqlException) {
			daoFactorySQLServer.cancelarTransaccion();
			throw new Exception("Se ha presentado un problema intentando actualizar un dato en la caja.");
		} catch (Exception exception) {
			daoFactorySQLServer.cancelarTransaccion();
			throw exception;
		} finally {
			daoFactorySQLServer.cerrarConexion();
		}
	}

	public ArrayList<CajaDTO> consultarTodo() throws Exception {
		DAOFactorySQLServer daoFactorySQLServer = new DAOFactorySQLServer();
		CajaNegocio cajaNegocio = new CajaNegocio();
		ArrayList<CajaDTO> cajaDTOLista = null;
		try {
			cajaDTOLista = cajaNegocio.consultarTodo(daoFactorySQLServer.obtenerConexion());
		} catch (SQLException exception) {
			throw new Exception("Se ha presentado un problema intentando consultar la caja.");
		} catch (Exception exception) {
			throw exception;
		} finally {
			daoFactorySQLServer.cerrarConexion();
		}
		return cajaDTOLista;
	}
}
